草庐IT

php - 将数组插入数据库表

全部标签

ruby-on-rails - 批量插入 rails 3

我想从我的Rails应用程序中批量插入几千条记录到数据库(在我的例子中是POSTGRES)。这样做的“Rails方式”是什么?一些快速且正确的方法。我知道我可以通过属性的字符串连接来创建SQL查询,但我想要一种更好的方法。 最佳答案 ActiveRecord.create方法支持批量创建。如果数据库不支持该功能,该方法将模拟该功能,如果支持该功能,则使用底层数据库引擎。只需传递一组选项。#CreateanArrayofnewobjectsUser.create([{:first_name=>'Jamie'},{:first_name

ruby - Rails 控制台中没有数据库连接

当我运行rakedb:migrate时,我的Rails应用程序工作正常,但当我尝试启动Rails控制台时出现问题。2.0.0p247:003>User=>User(nodatabaseconnection) 最佳答案 这是由于ActiveRecord从4.0开始懒惰地建立连接。别担心。第一次建立后,您将开始看到预期的输出。试试这个:2.1.4:001>User#=>User(call'User.connection'toestablishaconnection)2.1.4:001>User.count#=>SELECTCOUNT(*

ruby - 将 CSV 文件转换为哈希数组

我有一个csv文件,一些曲棍球统计数据,例如:09.09.2008,1,HCVitkoviceSteel,BKMladaBoleslav,1:0(PP)09.09.2008,1,HCLasselsbergerPlzen,RIOKNAZLIN,6:209.09.2008,1,HCLitvinov,HCSpartaPraha,3:5我想将它们保存在一个哈希数组中。我没有任何header,我想为每个值添加键,例如"time"=>"09.09.2008"等等。每行都应该像arr[i]一样可访问,每个值都应该像arr[i]["time"]一样可访问。我更喜欢CSV类而不是FasterCSV或sp

ruby-on-rails - rake 数据库 :reset 'user does not have CONNECT privilege'

所以我在我的Rails应用程序中使用HerokuPostgres,但我没有在Heroku本身上托管我的应用程序。我在我的database.yml中使用了来自Heroku的ActiveRecord连接详细信息,它看起来像这样:development:adapter:postgresqlencoding:unicodepool:5database:[database]username:[username]password:[password]host:ec2-54-227-243-78.compute-1.amazonaws.comport:5432但是,现在我正在尝试rakedb:mig

ruby - 将方法应用于数组/可枚举中的每个元素

这是我的数组:array=[:one,:two,:three]我想将to_s方法应用于我的所有数组元素以获取array=['one','two','three']。我该怎么做(将可枚举的每个元素转换为其他元素)? 最佳答案 这会起作用:array.map!(&:to_s) 关于ruby-将方法应用于数组/可枚举中的每个元素,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/64969

ruby-on-rails - 如何获取包含表的列名的数组

我需要一个包含表的列名的数组关于如何使用rails3.0.0rc做到这一点有什么想法吗? 最佳答案 假设您有一个Post模型:Post.column_names#orPost.columns.map{|column|column.name}它将返回一个数组,其中包含表“posts”的列名。 关于ruby-on-rails-如何获取包含表的列名的数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/qu

ruby - 根据另一个数组的元素对一个数组进行排序

我有一个id数组a1=[1,2,3,4,5]我还有另一个ID随机排列的对象数组a2=[(obj_with_id_5),(obj_with_id_2),(obj_with_id_1),(obj_with_id_3),(obj_with_id_4)]现在我需要根据a1中id的顺序对a2进行排序。所以a2现在应该变成:[(obj_with_id_1),(id_2),(id_3),(id_4),(id_5)]a1可能是[3,2,5,4,1]或任何顺序,但a2应对应于a1中id的顺序。我喜欢这样:a1.each_with_indexdo|id,idx|found_idx=a1.find_inde

ruby - 在 Ruby 中创建数字、字符串、数组或散列的 md5 散列

我需要在Ruby中为变量创建签名字符串,其中变量可以是数字、字符串、散列或数组。哈希值和数组元素也可以是这些类型中的任何一种。此字符串将用于比较数据库(在本例中为Mongo)中的值。我的第一个想法是创建一个JSON编码值的MD5散列,如下所示:(body是上面提到的变量)defcreatesig(body)Digest::MD5.hexdigest(JSON.generate(body))end这几乎可以工作,但是JSON.generate不会每次都以相同的顺序对散列的键进行编码,所以createsig({:a=>'a',:b=>'b'})并不总是等于createsig({:b=>'b

ruby - RSpec:如何在期望语法中使用数组包含匹配器

我使用newRSpecsyntax(expect而不是should)并且我想测试一个数组是否包含另一个数组的元素。在旧语法中它将是:array1.shouldinclude(array2)在我尝试编写的新语法中:expect(array1).toinclude(array2)但是我得到了一个错误(这很合理):TypeError:wrongargumenttypeArray(expectedModule)然后我写道:expect(array1).tobe_include(array2)但它很丑陋而且没有用:显然它检查array2是否是array1的元素,而不是检查array2的所有元素是

ruby - 用元素填充数组 N 次

我想用1个元素填充数组5次。到目前为止我得到了什么。number=1234a=[]5.times{a1234,1234,1234,1234,1234它可以工作,但感觉不是ruby​​的方式。有人可以指出正确的方向来初始化一个具有5倍相同值的数组吗? 最佳答案 对于Fixnums等不可变对象(immutable对象)Array.new(5,1234)#Assignsthegiveninstancetoeachitem#=>[1234,1234,1234,1234,1234]对于像字符串数组这样的可变对象Array.new(5){"Lo